<template>
  <div class="page-header-index-wide">
    <a-row :gutter="24">
      <a-col :sm="24" :md="12" :xl="6" :style="{ marginBottom: '24px' }">
        <chart-card :loading="loading" title="当前报名人数" total="1,560"></chart-card>
      </a-col>
      <a-col :sm="24" :md="12" :xl="6" :style="{ marginBottom: '24px' }">
        <chart-card :loading="loading" title="未审核人数" total="640"></chart-card>
      </a-col>
      <a-col :sm="24" :md="12" :xl="6" :style="{ marginBottom: '24px' }">
        <chart-card :loading="loading" title="已缴费人数" total="6560"></chart-card>
      </a-col>
      <a-col :sm="24" :md="12" :xl="6" :style="{ marginBottom: '24px' }">
        <chart-card :loading="loading" title="今日报名人数" total="78"></chart-card>
      </a-col>
    </a-row>

    <a-card :loading="loading" :bordered="false" :body-style="{padding: '0'}">
      <div class="salesCard">
        <a-tabs default-active-key="1" size="large" :tab-bar-style="{marginBottom: '24px', paddingLeft: '16px'}">
          <div class="extra-wrapper" slot="tabBarExtraContent">
            <div class="extra-item">
              <a>今日</a>
              <a>本周</a>
              <a>本月</a>
              <a>本年</a>
            </div>
            <a-range-picker :style="{width: '256px'}" />
          </div>
          <a-tab-pane loading="true" tab="报名人数" key="1">
            <a-row>
              <a-col :xl="16" :lg="12" :md="12" :sm="24" :xs="24">
                <bar :data="barData" title="报名人数" />
              </a-col>
              <a-col :xl="8" :lg="12" :md="12" :sm="24" :xs="24">
                <rank-list title="申报职位排行榜" :list="rankList"/>
              </a-col>
            </a-row>
          </a-tab-pane>
          <a-tab-pane tab="申报职位人数" key="2">
            <a-row>
              <a-col :xl="16" :lg="12" :md="12" :sm="24" :xs="24">
                <bar :data="barData2" title="申报职位人数" />
              </a-col>
              <a-col :xl="8" :lg="12" :md="12" :sm="24" :xs="24">
                <rank-list title="申报职位排行榜" :list="rankList"/>
              </a-col>
            </a-row>
          </a-tab-pane>
        </a-tabs>
      </div>
    </a-card>

    <div class="antd-pro-pages-dashboard-analysis-twoColLayout" :class="isDesktop() ? 'desktop' : ''">
      <a-row :gutter="24" type="flex" :style="{ marginTop: '24px' }">
        <!--        <a-col :xl="12" :lg="24" :md="24" :sm="24" :xs="24">-->
        <!--          <a-card :loading="loading" :bordered="false" title="线上热门搜索" :style="{ height: '100%' }">-->
        <!--            <a-dropdown :trigger="['click']" placement="bottomLeft" slot="extra">-->
        <!--              <a class="ant-dropdown-link" href="#">-->
        <!--                <a-icon type="ellipsis" />-->
        <!--              </a>-->
        <!--              <a-menu slot="overlay">-->
        <!--                <a-menu-item>-->
        <!--                  <a href="javascript:;">操作一</a>-->
        <!--                </a-menu-item>-->
        <!--                <a-menu-item>-->
        <!--                  <a href="javascript:;">操作二</a>-->
        <!--                </a-menu-item>-->
        <!--              </a-menu>-->
        <!--            </a-dropdown>-->
        <!--            <a-row :gutter="68">-->
        <!--              <a-col :xs="24" :sm="12" :style="{ marginBottom: ' 24px'}">-->
        <!--                <number-info :total="12321" :sub-total="17.1">-->
        <!--                  <span slot="subtitle">-->
        <!--                    <span>搜索用户数</span>-->
        <!--                    <a-tooltip title="指标说明" slot="action">-->
        <!--                      <a-icon type="info-circle-o" :style="{ marginLeft: '8px' }" />-->
        <!--                    </a-tooltip>-->
        <!--                  </span>-->
        <!--                </number-info>-->
        <!--                &lt;!&ndash; miniChart &ndash;&gt;-->
        <!--                <div>-->
        <!--                  <mini-smooth-area :style="{ height: '45px' }" :dataSource="searchUserData" :scale="searchUserScale" />-->
        <!--                </div>-->
        <!--              </a-col>-->
        <!--              <a-col :xs="24" :sm="12" :style="{ marginBottom: ' 24px'}">-->
        <!--                <number-info :total="2.7" :sub-total="26.2" status="down">-->
        <!--                  <span slot="subtitle">-->
        <!--                    <span>人均搜索次数</span>-->
        <!--                    <a-tooltip title="指标说明" slot="action">-->
        <!--                      <a-icon type="info-circle-o" :style="{ marginLeft: '8px' }" />-->
        <!--                    </a-tooltip>-->
        <!--                  </span>-->
        <!--                </number-info>-->
        <!--                &lt;!&ndash; miniChart &ndash;&gt;-->
        <!--                <div>-->
        <!--                  <mini-smooth-area :style="{ height: '45px' }" :dataSource="searchUserData" :scale="searchUserScale" />-->
        <!--                </div>-->
        <!--              </a-col>-->
        <!--            </a-row>-->
        <!--            <div class="ant-table-wrapper">-->
        <!--              <a-table-->
        <!--                row-key="index"-->
        <!--                size="small"-->
        <!--                :columns="searchTableColumns"-->
        <!--                :dataSource="searchData"-->
        <!--                :pagination="{ pageSize: 5 }"-->
        <!--              >-->
        <!--                <span slot="range" slot-scope="text, record">-->
        <!--                  <trend :flag="record.status === 0 ? 'up' : 'down'">-->
        <!--                    {{ text }}%-->
        <!--                  </trend>-->
        <!--                </span>-->
        <!--              </a-table>-->
        <!--            </div>-->
        <!--          </a-card>-->
        <!--        </a-col>-->
        <a-col :xl="24" :lg="48" :md="48" :sm="48" :xs="48">
          <a-card
            class="antd-pro-pages-dashboard-analysis-salesCard"
            :loading="loading"
            :bordered="false"
            title="申报职位类别占比"
            :style="{ height: '100%' }">
            <div slot="extra" style="height: inherit;">
              <!-- style="bottom: 12px;display: inline-block;" -->
              <!--              <span class="dashboard-analysis-iconGroup">-->
              <!--                <a-dropdown :trigger="['click']" placement="bottomLeft">-->
              <!--                  <a-icon type="ellipsis" class="ant-dropdown-link" />-->
              <!--                  <a-menu slot="overlay">-->
              <!--                    <a-menu-item>-->
              <!--                      <a href="javascript:;">操作一</a>-->
              <!--                    </a-menu-item>-->
              <!--                    <a-menu-item>-->
              <!--                      <a href="javascript:;">操作二</a>-->
              <!--                    </a-menu-item>-->
              <!--                  </a-menu>-->
              <!--                </a-dropdown>-->
              <!--              </span>-->
              <!--              <div class="analysis-salesTypeRadio">-->
              <!--                <a-radio-group defaultValue="a">-->
              <!--                  <a-radio-button value="a">全部渠道</a-radio-button>-->
              <!--                  <a-radio-button value="b">线上</a-radio-button>-->
              <!--                  <a-radio-button value="c">门店</a-radio-button>-->
              <!--                </a-radio-group>-->
              <!--              </div>-->

            </div>
            <div>
              <!-- style="width: calc(100% - 240px);" -->
              <div>
                <v-chart
                  :force-fit="true"
                  :height="405"
                  :data="pieData"
                  padding="auto"
                  :scale="pieScale">
                  <v-tooltip :showTitle="false" dataKey="item*percent" />
                  <v-axis />
                  <v-legend  dataKey="item"/>
                  <v-pie position="percent" color="item" :vStyle="pieStyle" :label="labelConfig"/>
                  <v-coord type="theta" :radius="0.9" :innerRadius="0.6" />
                </v-chart>
              </div>

            </div>
          </a-card>
        </a-col>
      </a-row>
    </div>
  </div>
</template>

<script>
import moment from 'moment'
import { ChartCard, MiniArea, MiniBar, MiniProgress, RankList, Bar, Trend, NumberInfo, MiniSmoothArea } from '@/components'
import { mixinDevice } from '@/utils/mixin'

const barData = []
const barData2 = []
for (let i = 0; i < 12; i += 1) {
  barData.push({
    x: `${i + 1}月`,
    y: Math.floor(Math.random() * 1000) + 200
  })
  barData2.push({
    x: `职位${i + 1}`,
    y: Math.floor(Math.random() * 1000) + 200
  })
}

const rankList = []
for (let i = 0; i < 7; i++) {
  rankList.push({
    name: '小学数学 ' + (i + 1) + '',
    total: 234 - i * 10
  })
}

const searchUserData = []
for (let i = 0; i < 7; i++) {
  searchUserData.push({
    x: moment().add(i, 'days').format('YYYY-MM-DD'),
    y: Math.ceil(Math.random() * 10)
  })
}
const searchUserScale = [
  {
    dataKey: 'x',
    alias: '时间'
  },
  {
    dataKey: 'y',
    alias: '用户数',
    min: 0,
    max: 10
  }]

const searchTableColumns = [
  {
    dataIndex: 'index',
    title: '排名',
    width: 90
  },
  {
    dataIndex: 'keyword',
    title: '搜索关键词'
  },
  {
    dataIndex: 'count',
    title: '用户数'
  },
  {
    dataIndex: 'range',
    title: '周涨幅',
    align: 'right',
    sorter: (a, b) => a.range - b.range,
    scopedSlots: { customRender: 'range' }
  }
]
const searchData = []
for (let i = 0; i < 50; i += 1) {
  searchData.push({
    index: i + 1,
    keyword: `搜索关键词-${i}`,
    count: Math.floor(Math.random() * 1000),
    range: Math.floor(Math.random() * 100),
    status: Math.floor((Math.random() * 10) % 2)
  })
}

const DataSet = require('@antv/data-set')

const sourceData = [
  { item: '小学语文', count: 32.2 },
  { item: '小学数学', count: 21 },
  { item: '小学英语', count: 17 },
  { item: '小学体育', count: 13 },
  { item: '小学美术', count: 9 },
  { item: '小学科学', count: 7.8 }
]

const pieScale = [{
  dataKey: 'percent',
  min: 0,
  formatter: '.0%'
}]

const dv = new DataSet.View().source(sourceData)
dv.transform({
  type: 'percent',
  field: 'count',
  dimension: 'item',
  as: 'percent'
})
const pieData = dv.rows

export default {
  name: 'Analysis',
  mixins: [mixinDevice],
  components: {
    ChartCard,
    MiniArea,
    MiniBar,
    MiniProgress,
    RankList,
    Bar,
    Trend,
    NumberInfo,
    MiniSmoothArea
  },
  data () {
    return {
      loading: true,
      rankList,

      // 搜索用户数
      searchUserData,
      searchUserScale,
      searchTableColumns,
      searchData,

      barData,
      barData2,

      //
      pieScale,
      pieData,
      sourceData,
      pieStyle: {
        stroke: '#fff',
        lineWidth: 1
      },
      labelConfig: ['percent', {
        formatter: (val, item) => {
          return item.point.item + ': ' + val
        }
      }]
    }
  },
  created () {
    setTimeout(() => {
      this.loading = !this.loading
    }, 1000)
  }
}
</script>

<style lang="less" scoped>
  .extra-wrapper {
    line-height: 55px;
    padding-right: 24px;

    .extra-item {
      display: inline-block;
      margin-right: 24px;

      a {
        margin-left: 24px;
      }
    }
  }

  .antd-pro-pages-dashboard-analysis-twoColLayout {
    position: relative;
    display: flex;
    display: block;
    flex-flow: row wrap;
  }

  .antd-pro-pages-dashboard-analysis-salesCard {
    height: calc(100% - 24px);
    /deep/ .ant-card-head {
      position: relative;
    }
  }

  .dashboard-analysis-iconGroup {
    i {
      margin-left: 16px;
      color: rgba(0,0,0,.45);
      cursor: pointer;
      transition: color .32s;
      color: black;
    }
  }
  .analysis-salesTypeRadio {
    position: absolute;
    right: 54px;
    bottom: 12px;
  }
</style>
